package com.test.course.array;

/**
 * @author sujiafa
 * @date 2025/7/3
 */
public class 插入排序 {

    public static void insertSort(int[] arr) {
        for (int i = 1; i < arr.length; i++) {
            int j = i;
            int temp = arr[j];
            // 如果前面的元素比当前元素大就继续往前移
            while (j > 0 && arr[j - 1] > temp) {
                arr[j] = arr[j - 1];
                j--;
            }
            arr[j] = temp;
        }
    }

    public static void main(String[] args) {
        // 测试用例1：随机顺序
        int[] arr1 = {64, 34, 25, 12, 22, 11, 90};
        System.out.println("排序前的数组：");
        printArray(arr1);
        insertSort(arr1);
        System.out.println("排序后的数组：");
        printArray(arr1);
    }

    public static void printArray(int[] arr) {
        for (int num : arr) {
            System.out.print(num + " ");
        }
        System.out.println();
    }
}
